package com.harveyguo.nihonngo.repositories;

import com.harveyguo.nihonngo.model.entity.BoxingGym;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;

import java.util.List;

/**
 * 拳馆Repository
 */
@Repository
public interface BoxingGymRepository extends JpaRepository<BoxingGym, String> {

    /**
     * 根据认证状态查找拳馆
     */
    List<BoxingGym> findByIsVerified(Boolean isVerified);

    /**
     * 根据名称模糊查找拳馆
     */
    List<BoxingGym> findByNameContaining(String name);

    /**
     * 根据地址模糊查找拳馆
     */
    List<BoxingGym> findByAddressContaining(String address);

    /**
     * 根据地理位置查找附近的拳馆
     */
    @Query("SELECT g FROM BoxingGym g WHERE " +
            "SQRT(POWER(g.latitude - :latitude, 2) + POWER(g.longitude - :longitude, 2)) <= :radius")
    List<BoxingGym> findNearbyGyms(@Param("latitude") Double latitude,
            @Param("longitude") Double longitude,
            @Param("radius") Double radius);
}